#include "cpu/exec/template-start.h"

#define instr cmp

static void do_execute() {
	DATA_TYPE result = op_dest->val - op_src->val;
	int len = (DATA_BYTE << 3) - 1;
	cpu.CF = op_dest->val < op_src->val;//judge jinwei
	cpu.SF=result >> len;//judge zhengfu
	int s1,s2;
	s1=op_dest->val>>len;
	s2=op_src->val>>len;
	cpu.OF=(s1 != s2 && s2 == cpu.SF) ;//judge yichu
	cpu.ZF=!result;//judge 0
	result ^= result >>4;
	result ^= result >>2;
	result ^= result >>1;									
	cpu.PF=!(result & 1);//judge ji ou
	print_asm_no_template2();								
}
#if DATA_BYTE == 2 || DATA_BYTE == 4
make_instr_helper(si2rm)
#endif
make_instr_helper(i2a)
make_instr_helper(i2rm)
make_instr_helper(r2rm)
make_instr_helper(rm2r)

														#include "cpu/exec/template-end.h"
